<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <script src="https://lf9-cdn-tos.bytecdntp.com/cdn/expire-1-M/vue/2.6.14/vue.js" type="application/javascript"></script>
</head>
<body>
  <div id="app">
    <tom></tom>
    <jerry></jerry>
  </div>
</body>
<script>
  // 混入
  // 用来给vue实列添加公共内容
  // 语法
  // 全局混入-所有vue实列
  // 注意事项
  // (1)如果数据/方法名重名，自己回覆盖全局的
  // (2)如果钩子函数重名，全局和自己的都会执行

Vue.mixin({
  //数据
  data () {
    return {
      username:'tom'
    }
  },
  // 钩子函数
  created () {
    console.log('123');
  },
  methods: {
    say(){
      console.log('say')

    }
  }
})
let obj = {
  data(){
    return {
      age:29  //定义对象
    }
  }
}
  Vue.component('tom', {
    template: `
      <div>{{username}}-<button @click='say'>say</button></div>
    `
  })
  Vue.component('jerry', {
    mixins: [obj],//局部混入
    data () {
      return {
        username:'jerry'
      }
    },
    created () {
    console.log('456');
  },
    template: `
      <div>j{{username}}-<button @click='say'>say</button></div>
    `
  })
  new Vue({
    data() {
      return {
      }
    },
    el: '#app'
  })
</script>
</html>
